草庐IT

Android:发送 HTTP POST 时出现 UnknownHostException

全部标签

amazon-web-services - 向多个设备发送 SNS 推送通知消息

我需要使用aws-sdk-go库向多个设备发送SNS推送通知并传递设备token数组。目前我正在使用以下步骤将推送消息发送到SNS:创建端点:pl,err:=svc.CreatePlatformEndpoint(&sns.CreatePlatformEndpointInput{PlatformApplicationArn:aws.String(topic),Token:aws.String(n.DeviceToken),//justonedevicetoken})发送消息到端点:params:=&sns.PublishInput{Message:aws.String(payload),

sockets - 如何在不阻塞服务器的情况下通过 tcp 向客户端发送数据?

我正在写一个游戏服务器,因为这是我的第一次,我一直想知道如何在不滞后服务器的情况下向客户端发送数据包。即使客户端滞后,也应该向他们发送数据包。(不确定这样做是否正确,但如果我不向他们发送数据包,客户端将不会同步)所以首先我的想法是:每个玩家在连接时都会获得2个goroutines:一个用于发送,另一个用于接收。//intheservermainloopselect{caseplayer.sendChan所以这里服务器的mainloop最多可以无阻塞地向播放器channel发送100个数据包,而sendPacket是阻塞的(可能是由于滞后)。但问题是如果播放器在100个数据包后阻塞,服务

logging - 无法发送 logrus 输出/dev/null

我正在使用Logrus用于登录我的项目的包。一切正常,但出于测试目的,我不需要显示logrus输出。我正在查看logrus.SetOuput寻找答案。所以基本上我希望将日志写入/dev/null但出于某种原因,我仍然在STDOUT上看到日志//Thiscoderunrightatthestartifenv=="test"{fmt.Println("Enteringtestmode....")logrus.SetOutput(ioutil.Discard)return}这是我的记录器设置的样子//logger.gopackageloggerimport("os""io/ioutil""g

json - 发送事件到 Datadog

不幸的是,没有官方的GoDatadogAPI。我目前正在使用这个https://github.com/zorkian/go-datadog-api.Datadogfork了第一个版本,推荐使用。我能够连接到我的仪表板:client:=datadog.NewClient("...","...")dash,err:=client.GetDashboard(...)iferr!=nil{log.Fatalf("fatal:%s\n",err)}但我不知道如何发送创建/跟踪事件。这是我目前的方法,但如果失败严重。c:=datadog.Client{}title:="Abc"e:=datadog

http - 发送 HTTP 响应被阻止,直到 shell 命令完成

想法:有一个Web服务器准备好接收消息,这些消息将触发在服务器上执行命令/测试。我从一个执行简单ping的简单案例开始。下面的代码处理发送到/ping的POST消息,其中包含以下json格式:{"ip":"valid_ip_addr","count":"4"}然后服务器将运行命令ping-c4valid_ip_address期望的结果:如果命令可以.Start()发回200OK。如果有问题,发回错误信息。问题:我在检查.Start()没有给出任何错误后立即发送了一个200OK响应,但这是命令完成后接收。代码:共有三个函数:main()、handler()和ping()。问题出现在最后一

sockets - 如何为 Go 中写入的每个连接发送单独的数据包?

问题我想运行一个每秒有大量请求的负载测试。我在Go中编写了一个套接字发送器和一个接收器。发送方向端口7357发送大量数据包,每个数据包都包含以纳秒为单位的当前时间。接收方在端口7357上监听并解析每条消息,计算延迟。问题是在读取时我在一个conn.Read()中得到了多个数据包。我知道这意味着我实际上每个数据包发送多条消息:每个conn.Write()不发送套接字数据包,但它等待一段时间然后与下一个合并(或接下来的几个)在发送之前。问题如何确保每个conn.Write()都作为单独的数据包通过套接字单独发送?注意:我不想重新发明TCP,我只想模拟来自多个外部实体的负载,每个实体发送一条

multithreading - Go 服务器在发送 INT 信号后挂起

代码如下:packagemainimport("log"_"net/http/pprof""fmt""net/http""html""os/signal""os")funcmain(){//INTsignalhandlingc:=make(chanos.Signal,1)signal.Notify(c,os.Interrupt)gofunc(){forrangec{log.Println("GOTSIGNAL!")return}}()//INTsignalhandlinghttp.HandleFunc("/bar",func(whttp.ResponseWriter,r*http.Re

firebase - 在 golang 应用程序中初始化 firebase 时出错

我正在使用firebasegosdk(https://github.com/acoshift/go-firebase-admin)并按照文档设置我的应用程序。但是当我尝试使用firebase.NewApp初始化应用程序时,我收到一条错误消息google:couldnotfinddefaultcredentials.谁能帮忙这是代码片段opt=option.WithCredentialsFile(viper.GetString("firebase"))app,err=firebase.NewApp(context.Background(),nil,opt)iferr!=nil{log.F

go - 在 GO 中解析时间时出现奇怪的错误消息

我尝试在go中将字符串解析为时间,这是我所做的:dateTime:=fmt.Sprintf("%s%sCST",dateValue,timeValue)date,err:=time.Parse("2006-1-2150405MST",dateTime)我收到以下错误信息:解析时间“2012-4-9174031CST”为“2006-1-2150405MST”:无法将“2012-4-9174031CST”解析为“2006”从报错信息来看,我传入的dateTime值是正确的。我还尝试执行以下操作,效果很好:dateTime:="2012-4-9174031CST"date,err:=time

go - 在 Circle Ci Golang 上导入包时出现问题

我正在使用CircleCI来测试我的项目。该项目是一个简单的Go应用程序,由几个包和一个main.go文件组成。在我的项目中引用包时,我只是将它们作为代码中的“projectName/packageName”导入。这在本地工作正常,但是,当我推送到git并且它是在CircleCI上构建时,我收到以下错误。packagecrypto-compare-go/handlers:unrecognizedimportpath"crypto-compare-go/handlers"(importpathdoesnotbeginwithhostname)我通过在本地包导入前加上github.com/